草庐IT

c++ - QML Qt openUrlExternally

全部标签

c++ - GCC - 包含编译标志的宏

GCC中是否有包含用于编译程序的编译标志的宏?我想要这样的东西:printf("Compilationflags:%s",__FLAGS__);以输出为例:Compilationflags:-02-g 最佳答案 简短回答:否。稍微长一点的答案:即使有,你的代码也会变得不可移植。需要这种功能的项目让构建系统来做,例如通过将所有标志放在make的CFLAGS变量中,并创建一个config.h规则,将所有这些标志放在中#define那里。 关于c++-GCC-包含编译标志的宏,我们在Stack

c++ - 是基类型的有符号/无符号部分还是限定符

Wikipage声称C++中的限定符是const和volatile。Thisanswer告诉unsigned、unsigned和short等也是限定符。虽然问题确实提到了它是关于C的,但Wikipage在C方面也没有说明。对于C,限定符是const、volatile、restrict和_Atomic。StackOverflow的qualifier标签的扩展消息框说Aqualifieraddsanextra"quality",suchasspecifyingvolatilityorconstnessofavariable“Addanextraquality”,从引文来看,singed/u

c++ - 访问结构的 union 成员的优雅方式

有没有办法反转#define指令?在下面的例子中#defineZERO0#defineONE1#defineTWO2#defineTHREE3是否可以从整数值2中检索出TWO?此示例来自C代码,但如果需要,我可以使用一些C++代码。我的目标是能够分解一些这种形式的虚假switch-case循环:switch(num){caseZERO:returnstd::to_string(foo.V_ZERO);caseONE:returnstd::to_string(foo.V_ONE);caseTWO:returnstd::to_string(foo.V_TWO);caseTHREE:retu

c++ - fprintf/fputs 与大字符串的 cout 性能

当我对fprintf()进行测试时,fputs(),和ofstreamoperator(,我意识到C函数(两者)提供了更好的运行时性能,但是当输入字符串变大时,两个C函数的运行速度都比C++的运算符慢。我想知道C++在小字符串上表现不佳的原因,以及它在大字符串上优于C的原因。欣赏它。注意:不幸的是,我无法共享大小超过1000个字符的字符串。测试结果-StringSize->20chars,C++(50chars,C++(1000chars,C++(2000chars,C++(50000chars,C++(100000chars,C++(这是代码#include#include#incl

c++ - 如何获得忘记算术运算的警告?

考虑这种情况:uint64_tadd(uint32_ta,uint32_tb){returna+b;//programmerneglected(uint64_t)a+b.}我们如何让GCC(或任何其他编译器)的C或C++前端对这种情况发出警告:正在以立即加宽的窄类型执行操作?我通读了当前的GCC文档,并尝试了各种警告,例如-Wconversion,但没有任何效果。 最佳答案 我不知道GCC的标志会引起警告。Coverity静态分析器将发出OVERFLOW_BEFORE_WIDEN警告,因为这已在CERT标准中标记。免责声明:我曾为C

c++ - 将宏名称传递给 X-Macro 列表是否合法

我想到以下是X-macro的更可取的样式技巧:#defineLIST_OF_COLOURS(X)\X(RED)\X(GREEN)\X(BLUE)#defineLIST_OF_FRUIT(X)\X(APPLE)\X(ORANGE)\X(TOMATO)具体来说,将X宏传递给列表,而不是在每次实例化列表时取消定义并重新定义它。这允许:#defineX_LIST(x)x,#defineX_STRING_LIST(x)#x,#defineCOMPREHENSIVE_SETUP(n,l)\enumn{l(X_LIST)};\charconst*n##Names[]={l(X_STRING_LIST

c++ - 在 Linux 上的发布/优化二进制文件中的信号处理程序中打印回溯

问题是关于在优化的二进制文件中以编程方式打印有意义的堆栈跟踪。例如我们可以使用backtrace、backtrace_symbols、abi::__cxa_demangle来打印堆栈跟踪。但据我所知,我们需要使用编译器标志-g构建二进制文件,而不是高于-O1优化标志。我能做到这一点。我期待在发布二进制文件中生成具有正确函数名称的回溯,例如使用-O3标志编译。它可行吗?我对此做了很多研究,但没有得到任何实质性的东西。更新1:有没有一种方法可以让我们拥有一个包含一些符号的辅助文件,并且可以引用它来从优化的二进制进程中生成堆栈跟踪? 最佳答案

c++ - 如何在运行时指定数组的维数和?

我正在研究建立分布熵的函数。它使用一个copula,如果有人熟悉的话。我需要根据“关心”的维度来总结数组中的值。示例:考虑以下示例...Dimension0(across)_____________|_0_|_0_|_0_|_2_|Dimension1|_1_|_0_|_2_|_0_|(down)|_0_|_3_|_0_|_6_||_0_|_0_|_0_|_0_|I"careabout"dimension0only,and"don'tcare"abouttherest(dim1).Summingthisarraywiththeabovespecificationswill"collap

c++ - C/C++ 的广泛执行

是否有exec[lv][pe]的wchar_t版本(即使用wchar_t的exec>作为路径和wchar_t作为参数)?在Windows中,我可以只执行CreateProcessW(process,cmdline),但在*nix中,我卡住了(即没有纯POSIX等效)。我正在尝试为我的程序添加UTF-16支持(自动运行)。 最佳答案 没有。在UNIX中,与环境交互时习惯使用UTF-8。 关于c++-C/C++的广泛执行,我们在StackOverflow上找到一个类似的问题:

c++ - C/C++ 中的领域特定语言,这是 Kosher 吗?

当我想出这个“奇怪”的解决方案时,我只是在为C/C++中的新项目设计一些领域特定语言设计:defineDSL(...)MakeCommand(#__VA_ARGS__\)->Exec()->GetResults()MyResultsresults=DSL(forpinpeopledosomething);好的部分是这是符合标准的(但DuffSwitch也是如此),并且跨平台、可移植等……然而,这种方法实际上并不比将字符串写入代码更好,但是由于DSL引擎无论如何都会解析字符串,这样看起来更漂亮,并且减少了困惑。但想知道其他人对此有何看法。谢谢 最佳答案